УДК 621.3.049.77:004.032.34:004.312

Реализация синтеза самосинхронных схем в базисе БМК

*Плеханов Леонид Петрович1), Денисов Андрей Николаевич2), Дьяченко Юрий Георгиевич1), Мамонов Дмитрий Игоревич2), Морозов Николай Викторович1), Степченков Дмитрий Юрьевич1)*

1)Институт проблем информатики Федерального Исследовательского Центра "Информатика и управление" Российской академии наук, 119333, г. Москва, ул. Вавилова, д .44, корп. 2, <http://www.ipiran.ru>,

E-mail: lplekhanov@inbox.ru, +79162774834

2)Научно-производственный комплекс "Технологический центр" (НПК "Технологический центр"),

244980, Москва, Зеленоград, проезд 4806, д.5, <http://www.asic.ru>,E-mail: [den@tcen.ru](mailto:den@tcen.ru), +74997208992

**Аннотация**

Доклад посвящен реализации автоматизированного синтеза самосинхронных (CC) схем на основе описания схемы на языке Verilog и библиотеки стандартных элементов 5503, расширенной специфичными для СС-схем элементами 5503СС. Программа синтеза имеет оконный интерфейс и интегрируется в САПР "Ковчег" СБИС на базовых матричных кристаллах. Приводится сравнение результатов автоматического и ручного синтеза.

**Ключевые слова**: самосинхронные схемы; автоматизированный синтез; синтез самосинхронных схем; маршрут проектирования.

**1 Введение**

В предыдущей работе [1] были приведены основные принципы и подходы в организации синтеза самосинхронных (СС) схем в рамках САПР цифровых устройств. В продолжение темы, данный доклад конкретизирует способы реализации такого синтеза.

Самосинхронные схемы обладают рядом уникальных свойств, недостижимых при синхронной и других асинхронных реализациях: отсутствием состязаний при любых задержках элементов, предельно широкими областями работоспособности по температуре и напряжению питания, полной остановкой при возникновении константных неисправностей типа залипания и некоторыми другими. Эти свойства обоснованы теоретически и подтверждены экспериментально [2– 4]. Такие свойства СС-схем обеспечиваются их специальным построением и режимом функционирования.

Функционирование СС-схем осуществляется чередованием двух фаз: рабочей и вспомогательной (спейсерной) фазы. В рабочей фазе делаются необходимые логические преобразования сигналов, в спейсерной фазе выполняются вспомогательные действия. В обеих фазах подтверждается окончание всех переходных процессов и формируется единый подтверждающий сигнал. Каждая очередная фаза начинается только после подтверждения по обратной связи окончания переходных процессов в предыдущей фазе. Процесс формирования сигнала окончания переходных процессов далее будем называть *индикацией*.

Для организации двухфазного режима и различения процессов в фазах используется построение логики с помощью СС-кодов [2], в данном случае парафазного кода (ПФ-кода). В ПФ-коде каждый исходный информационный сигнал представляется двумя сопряженными сигналами. В рабочей фазе каждая такая пара сигналов имеет взаимно-обратные значения: 01 представляет информационную единицу, 10 – информационный ноль. В спейсерной фазе (спейсере) оба сигнала одинаковы и равны 00 или 11 в зависимости от места в схеме.

Обобщенно процедура предлагаемого синтеза состоит в преобразовании Verilog-описания схемы с верхних уровней в систему логических функций, переводе функций в ПФ-код, генерации регулярных конструкций (счетчиков, регистров и т.п.), подборе библиотечных элементов для их реализации и организации индикации всей схемы.

**2 Постановка задачи**

Синтез проводится на элементах заранее подготовленной библиотеки (*базовой библиотеки*).

Для синтеза предъявляются:

- исходное описание схемы на языке Verilog любого уровня – функций, регистровых передач, верхнего,

- параметры синтеза (задание на синтез).

Задача состоит в создании СС-схемы на элементах базовой библиотеки с критерием минимизации сложности [1] и учетом нагрузочной способности элементов.

Сложность элементов, нагрузки входов (входные емкости) и нагрузочные способности выходов задаются в базовой библиотеке. Нагрузка на выходах элементов синтезируемой СС-схемы вычисляется как сумма емкостей присоединенных входов и паразитной емкости трасс. На предварительном этапе, при отсутствии данных из топологии, трассы учитываются усредненно: подсчитывается число «веток» трассы и умножается на средний коэффициент, заданный в библиотеке. "Ветками" считаются выход элемента и присоединенные к нему входы.

**2.1 Исходное описание схемы**

Исходное описание схемы на языке Verilog допускает иерархию, наличие переменных, векторов и регистров. Функционирование схемы описывается на любом уровне. Например, для описания суммирования достаточно использовать конструкцию:

*assign Sum = A + B*;

где *A* и *B* – векторы любой заданной длины.

Если в исходной схеме используются готовые СС-модули, для корректного встраивания в синтезируемую схему их интерфейсы должны быть описаны в специальном разделе библиотеки – макроэлементах.

**2.2 Параметры синтеза**

В отдельном файле – задании на синтез – приводится информация, определяющая СС-атрибуты входов и выходов результирующей схемы и другие необходимые для синтеза данные. Пример задания для синтеза умножителя 4×4 показан на рис. 1.

**//=============================================================**

**// Task for synthesis**

**//=============================================================**

**Sour\_file: Mult\_4x4.v; // source file**

**Module: mult\_buta; // module to synthesize**

**IN\_Space\_0: \* ; // names or \* (all)**

**IN\_Space\_1: ; // --"--**

**IN\_Indics: ; // --"-- to be indicate on total OUT unar-phase**

**OUT\_Indics: \* ; // --"-- --"--**

**SS\_Amplify: \* ; // amplify ST-circuit's signals**

**OutLang: Verilog; // Verilog, VHDL, Form (FormatKey)**

Рис. 1 Пример задания для синтеза умножителя 4×4

Обязательно задание спейсерных значений всех входов схемы (параметры **IN\_Space\_0** и **IN\_Space\_1** на рис. 1). Выходные спейсеры (параметры **OUT\_Space\_0** и **OUT\_Space\_1**) могут быть заданы, и они будут обеспечены при синтезе (в данном примере на рис. 1 они отсутствуют). Незаданные выходные спейсеры определяются при синтезе автоматически, исходя из критерия минимальной сложности.

Опционально задаются требования индикации внешних входов и выходов схемы на общем индикаторном СС-выходе схемы (параметры **IN\_Indics** и **OUT\_Indics** на рис. 1). (По условиям самосинхронности все внутренние сигналы СС-схемы будут индицированы на этом выходе автоматически).

Параметр усиления (**SS\_Amplify**) дает гибкую возможность согласовать реальные нагрузки с нагрузочными способностями элементов СС-схемы:

- усилить все сигналы, формируемые элементами, нагрузочная способность которых меньше их нагрузки в схеме,

- не усиливать никакие сигналы,

- усилить указанные пользователем сигналы СС-схемы.

Параметр "**OutLang**" задает язык описания синтезированной схемы.

Регистры, счетчики и другие подобные устройства регулярной структуры в СС-схемах строятся специальным способом, поэтому в исходных данных необходимо задавать их параметры: разрядность, тип и другие. В процессе синтеза такие устройства будут сгенерированы автоматически.

**3 Процедура синтеза**

Синтез проводится в несколько этапов.

*Этап 1. Предварительная обработка.*

На первом этапе используется программа с открытым кодом Yosys [5]. Она переводит Verilog-описание схемы любого уровня в систему логических функций с числом аргументов не более трех. Такое преобразование весьма удобно для синтеза, так как позволяет избежать операций декомпозиции функций и эффективно использовать элементы базовой библиотеки.

*Этап 2. Генерация заданных устройств и встраивание макроэлементов (внешних готовых СС-схем).*

По описанию макроэлементов в исходной схеме и указанию в задании будут сгенерированы устройства необходимой разрядности и заданными СС-атрибутами из элементов базовой библиотеки. На текущий момент генерируются наиболее востребованные устройства: регистры хранения, регистры сдвига и счетчики. В дальнейшем список подобных устройств может быть расширен.

Внешние СС-схемы встраиваются в соответствии с их интерфейсами, находящимися в разделе макроэлементов базовой библиотеки. Интерфейсы должны содержать описания портов и их СС-атрибуты.

*Этап 3. Выделение и балансировка комбинационных фрагментов.*

На этом шаге выделяются комбинационные части схемы и определяются их СС-атрибуты по атрибутам входов-выходов схемы из задания и атрибутам генерируемых и встраиваемых устройств.

В каждом фрагменте путем подстановок исключаются константы и инверторы и удаляются промежуточные функции-константы. Далее проводится укрупнение функций путем подстановок таким образом, чтобы после перевода их в ПФ-код в базовой библиотеке нашлись элементы для реализации обоих компонентов ПФ-кода. Укрупнение позволяет снизить общую сложность схемы. Элементы выбираются с учетом критерия минимальной сложности.

Этот способ гарантирует покрытие получаемых функций элементами базовой библиотеки.

*Этап 4. Синтез комбинационных фрагментов схемы.*

На данном шаге исходные функции переводятся в ПФ-код и подбираются покрывающие их библиотечные элементы.

Выполняется согласование спейсеров: на входы каждой пары ПФ-функций должны подаваться сигналы с одинаковым спейсером. При необходимости добавляются согласующие инверторы.

*Этап 5. Синтез индикаторной подсхемы.*

Индикация связана с необходимостью использования в СС-схемах особых сигналов, показывающих текущую фазу работы схемы – унарных фазовых (УФ) сигналов. Такие сигналы в процедуре синтеза появляются при генерации СС-устройств и встраивании внешних СС-схем. Кроме того, УФ-сигналы появляются и при построении самой индикации.

Индикаторная подсхема решает две задачи: получает от каждой пары ПФ-функций (элементов) один УФ-сигнал и объединяет все частичные УФ-сигналы в один общий индикаторный сигнал схемы.

УФ-сигнал ПФ-пары получается подключением на выходы пары 2-входового элемента: ИЛИ (или ИЛИ-НЕ) для пары со спейсером 00 и И (или И-НЕ) для пары со спейсером 11.Для объединения УФ-сигналов в один общий индикаторный выход применяются гистерезисные триггеры (Г-триггеры) [2]. Существует несколько разновидностей Г-триггеров:

- только с ПФ-входами (2 пары входов),

- только с УФ-входами (от 2 до 4 входов),

- с ПФ и УФ входами с общим числом входов до четырех.

На выходе Г-триггера формируется один УФ-сигнал.

Для улучшения быстродействия и уменьшения сложности индицировать окончание переходных процессов целесообразно по каскадам. Каскад – это множество элементов и макроэлементов, все входы которых принадлежат предыдущим каскадам. Начальным каскадом служат входы схемы. В каждом каскаде предпочтительно обеспечивать максимальную степень сжатия за счет использования Г-триггеров с максимально допустимым числом входов. Оставшиеся незадействованными УФ-сигналы учитываются в следующих каскадах. После последнего каскада формируется общий для всей схемы индикаторный УФ-сигнал.

Одновременно при построении индикации вводятся согласующие инверторы для обеспечения требуемых значений спейсеров на выходах комбинационных фрагментов, Г-триггеров и всей схемы.

*Этап 6. Усиление.*

После построения всей схемы проверяется соответствие нагрузок элементов схемы их нагрузочным способностям. Вся эта информация предоставляется пользователю в журнальном файле. Далее пользователь может специфицировать в файле задания на синтез сигналы, требующие усиления с помощью параметра "**SS\_Amplify**", и повторить синтез.

**4 Результат синтеза**

Результатом синтеза является описание СС-схемы на языке, определенном заданием на синтез. Рис. 2 демонстрирует в качестве примера начало файла описания синтезированного умножителя 4×4. Входы и выходы схемы представляются соответствующими парами сигналов в ПФ-коде. Дополнительным выходом служит общий индикаторный сигнал (**\_UI\_79**).

После описания портов приводятся их СС-атрибуты в формате Verilog, содержащие:

- тип сигналов: парафазные ("**BinPhas**"), унарные ("**UnPhas**") или иные,

- спейсерные значения входов и выходов (цифра 0 или 1 в конце списка сигналов в описании атрибута),

- указания, какие входы и выходы схемы индицируются общим индикаторным сигналом ("**PhasOut**").

Схема, полученная в результате логического синтеза, является самосинхронной и не требует дальнейшей проверки на это свойство. Однако реальные емкости трасс, получившиеся при проектировании топологии, могут потребовать дополнительной корректировки схемы по усилению элементов, что планируется в дальнейшем развитии программы синтеза.

**5 Требования к библиотеке**

Библиотека элементов для проектирования СС-схем отличается от стандартных библиотек своим составом. Рассмотрим вопрос о типе и минимально необходимом наборе элементов для предложенного синтеза.

В соответствии с теорией [2], для реализации комбинационной логики могут использоваться только элементы с монотонной функцией: изотонной или антитонной. Функция является изотонной, если существует ее дизъюнктивная нормальная форма (ДНФ), в которой все аргументы используются без отрицаний. Функция является антитонной, если существует ее ДНФ, в которой все аргументы используются с отрицаниями.

В схемах, изготавливаемых по технологии "комплементарный металл-диэлектрик-полупроводник" (КМДП) антитонными являются все однокаскадные элементы с одним выходом. В таких элементах все входы подключены к затворам транзисторов, стоящих непосредственно в цепях переключения нагрузки. Если к выходу однокаскадного элемента подключить инвертор, то получится изотонный элемент, также пригодный для синтеза.

**//======================================================//**

**// 25.07.2021 20:46 SS-Synthesis v.3.1 //**

**//======================================================//**

**//Prefixes for SS-names:**

**//"\_M" - PFS main**

**//"\_C" - PFS conjugate**

**//"..\_I\_" - inverse signal for PFS**

**//"\_WW\_" - inverse signal to agree**

**//"\_UI\_" - unary indicator**

**//"\_LAB\_" - label**

**//Library: MSS\_5503**

**//+++++++++++++++++++++++++++++++++++++++++++++++++++++++**

**module mult\_buta\_SS (\_M\_data\_in1, \_C\_data\_in1, \_M\_data\_in2, \_C\_data\_in2,**

**\_M\_data\_out, \_C\_data\_out, \_UI\_79);**

**input [3:0] \_M\_data\_in1, \_C\_data\_in1, \_M\_data\_in2, \_C\_data\_in2;**

**output [7:0] \_M\_data\_out, \_C\_data\_out;**

**output \_UI\_79;**

**// - - - - - - - - - - - - - - - - - - - - - - - - - - - - -**

**(\*UnPhas="\_UI\_79 1"\*)**

**(\*BinPhas={"\_M\_data\_in1[3] \_C\_data\_in1[3] \_M\_data\_in1[2] \_C\_data\_in1[2]",**

**" \_M\_data\_in1[1] \_C\_data\_in1[1] \_M\_data\_in1[0] \_C\_data\_in1[0]",**

**" \_M\_data\_in2[3] \_C\_data\_in2[3] \_M\_data\_in2[2] \_C\_data\_in2[2]",**

**" \_M\_data\_in2[1] \_C\_data\_in2[1] \_M\_data\_in2[0] \_C\_data\_in2[0] 0",**

**" \_M\_data\_out[7] \_C\_data\_out[7] \_M\_data\_out[6] \_C\_data\_out[6]",**

**" \_M\_data\_out[5] \_C\_data\_out[5] \_M\_data\_out[4] \_C\_data\_out[4]",**

**" \_M\_data\_out[3] \_C\_data\_out[3] \_M\_data\_out[2] \_C\_data\_out[2]",**

**" \_M\_data\_out[1] \_C\_data\_out[1] \_M\_data\_out[0] \_C\_data\_out[0] 1"}\*)**

**(\*PhasOut={"\_UI\_79 <\*> \_M\_data\_out[7] \_C\_data\_out[7] \_M\_data\_out[6]",**

**" \_C\_data\_out[6] \_M\_data\_out[5] \_C\_data\_out[5] \_M\_data\_out[4]",**

**" \_C\_data\_out[4] \_M\_data\_out[3] \_C\_data\_out[3] \_M\_data\_out[2]",**

**" \_C\_data\_out[2] \_M\_data\_out[1] \_C\_data\_out[1] \_M\_data\_out[0]",**

**" \_C\_data\_out[0]"}\*)**

**// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -**

**wire [7:1] \_M\_005\_, \_C\_005\_;**

Рис. 2 Пример описания результата синтеза умножителя 4×4

Таким образом, в КМДП-библиотеке достаточно иметь только антитонные элементы, включая инвертор, изотонные функции из них получить легко.

Как было сказано выше, предварительный этап синтеза дает описания функций с числом аргументов до трех. Из этого следует, что для комбинационной логики в библиотеке необходимо иметь все антитонные элементы с таким числом входов.

Из процедуры индикации следует, что все УФ-сигналы можно получить с помощью двухвходовых элементов, входящих в необходимый набор. Также из теории известно [2, 3], что любое количество УФ-сигналов можно объединить в один с помощью Г-триггеров с двумя УФ-входами.

В итоге минимальный набор библиотеки элементов для синтеза включает:

- инвертор,

- 2 элемента с двумя входами: И-НЕ, ИЛИ-НЕ,

- 5 антитонных элементов с тремя входами,

- СС-триггер хранения,

- счетный СС-триггер,

- СС-ячейку сдвига,

- Г-триггер с двумя УФ-входами.

Однако для улучшения быстродействия и снижения сложности синтезируемых схем крайне желательно включать в библиотеку не только антитонные, но и изотонные элементы, а также элементы с числом входов более трех. Кроме того, желательно иметь в библиотеке разные триггерные ячейки и Г-триггеры со входами всех типов.

Для проектирования СС-схем на базовом матричном кристалле (БМК) была создана библиотека [6], насчитывающая более 250 элементов с числом входов до девяти.

Для примера, результат синтеза умножителя 4×4 (в составе СС-ядра микроконтроллера [7]) на библиотеке [6] был получен с использованием комбинационных элементов до восьми входов включительно и всех типов Г-триггеров, перечисленных в *Этапе 5* раздела 3.

Состав библиотеки для синтеза напрямую влияет на характеристики синтезируемых схем. Известная методология проектирования СС-схем, называемая NULL Convention Logic (NCL) [8], использует для синтеза весьма ограниченную библиотеку, включающую 29 элементов с нулевым спейсером. С одной стороны, это облегчает формализацию синтеза. С другой стороны, получающиеся NCL-схемы обладают большей сложностью (в 4,49 раза при реализации двоичного счетчика, в 1,13 раза при реализации умножителя 4×4, до 2 раз при реализации более простых логических схем), худшим быстродействием и повышенным энергопотреблением в сравнении с СС-схемами, синтезированными на базе предлагаемого подхода и библиотеки.

**6 Эффективность автоматизированного синтеза**

Известно, что автоматический синтез часто уступает ручному по ряду показателей. В данном случае это может происходить в комбинационной схеме или ее части.

Например, сложность автоматически созданного 4-разрядного комбинационного сумматора с последовательным переносом получилась на 30% больше сложности варианта, спроектированного вручную на элементах той же библиотеки. Анализ показал, что вручную разработчик использовал сложный библиотечный элемент, реализующий функцию суммы трех слагаемых в ПФ-коде. Доля такого элемента в сумматоре оказалась значительной. Программа синтеза пока такие элементы не привлекает.

В других случаях, когда доля суммирующей логики меньше, превышение аппаратных затрат получается меньше. Комбинационный умножитель 4×4 по алгоритму Бута, синтезированный программой, уже лишь на 20% сложнее аналога, спроектированного вручную, из-за наличия не только сумматоров, но и другой комбинационной логики. Чем больше доля простой логики в комбинационной СС-схеме, тем ближе по аппаратной сложности оказываются варианты, синтезированные автоматически и вручную.

Данный опыт показал, что для уменьшения сложности необходимо совершенствовать алгоритм синтеза в направлениях:

- анализировать пары логических функций на предмет их связности по входам,

- использовать библиотечные комбинационные элементы с несколькими выходами.

Это позволит применить компактные схемотехнические решения, формирующие ПФ-сигналы одной принципиальной схемой с двумя выходами, которые сейчас не выявляются и не используются.

Например, функция сложения трех переменных по модулю два:

*Y = A ⊕ B ⊕ C*

при синтезе СС-схемы преобразуется в пару функций с парафазными переменными {*A, AB*}, {*B, BB*}, {*C, CB*}:

*Y = A·B·C + A·BB·CB + AB·BB·C + AB·B·CB*,

*YB = AB·B·C + A·BB·C + A·B·CB + AB·BB·CB*.

Эти функции реализуется принципиальной схемой на КМДП-транзисторах, показанной на рис. 3, содержащей 24 КМДП-транзистора и не нарушающей ограничения на число последовательно соединенных транзисторов (не более трех) в цепочках между шинами питания и "земли" и выходом схемы.

![Fig_1.tif](data:image/tiff;base64,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)

Рис. 3 Принципиальная схема элемента сложения по модулю два   
с тремя парафазными входами и парафазным выходом

Аналогичная ситуация получается при выполнении СС-схемой функций сложения по модулю два от двух и четырех переменных и некоторых других сильно связанных функций, допускающих компактную реализацию в виде двухвыходовой принципиальной схемы.

В отличие от комбинационных СС-схем, последовательностные схемы при автоматическом синтезе получаются практически идентичными ручным вариантам за счет формализованного подхода, воплощающего эвристические принципы построения регистровых устройств и счетчиков из библиотечных триггерных элементов.

Таким образом, эффективность программы автоматизированного синтеза СС-схем соответствует стандартным САПР для большей части типов СС-устройств. Ввод в программу синтеза эвристического алгоритма выявления функций, сильно связанных по переменным, обеспечит уменьшение сложности синтезируемых автоматически СС-схем до уровня, соответствующего сложности результатов ручного проектирования.

**7 Новизна результатов**

Авторы считают, что в данной работе новой является методика синтеза СС-схем на основе теории самосинхронности и специализированной библиотеки элементов для проектирования СС-схем на БМК, интегрированной в САПР "Ковчег" (НПК «Технологический центр»). Постановка задачи синтеза СС-схем и приведенный алгоритм реализации являются уникальными и не встречаются в публикациях.

**8 Заключение**

Особенности СС-схем: двухфазный режим работы, специальное кодирование сигналов и их индицирование диктуют специальные методы проектирования таких схем. К этим методам относятся: дуализация (перевод логических функций в один из СС-кодов, в данном случае парафазный) и построение индикаторной подсхемы.

Расширение библиотеки стандартных элементов САПР "Ковчег" СБИС на БМК элементами, необходимыми для проектирования СС-схем, обеспечило успешную интеграцию в нее специфичных этапов проектирования СС-схем и получение единого маршрута автоматизированного проектирования синхронных и СС-схем. Существенными отличиями маршрута синтеза СС-схемы от маршрута проектирования синхронных схем являются этап повторного синтеза логики и этап анализа на самосинхронность после топологического синтеза. Последний анализ проверяет отсутствие нарушений самосинхронности, привнесенных топологической реализацией схемы.

Предложенный способ синтеза обеспечивает получение схем, обладающих меньшей сложностью и более высоким быстродействием в сравнении со схемами, синтезированными в соответствии с существующей NCL-методологией.

Сравнение с результатами ручного проектирования показывает, что в суммирующих и некоторых других схемах для уменьшения сложности и улучшения быстродействия целесообразно находить и использовать компактные СС-элементы с парафазными выходами.

Дальнейшее развитие методов синтеза будет идти в направлениях выявления и реализации сильно связанных функций, увеличения списка автоматически генерируемых структур, учета данных реальной топологии.

**9 Поддержка**

Исследование выполнено в рамках государственного задания № 0063-2019-0010.

**Список литературы**

**[**1] Л.П. Плеханов, А.Н. Денисов, Ю.Г. Дьяченко, Ю.А. Степченков, Д.И. Мамонов, Д.Ю. Степченков. Синтез самосинхронных схем в базисе БМК / Научная конференция «Микроэлектроника – ЭКБ и электронные модули»*.* Алушта (Республика Крым), 30.09-05.10.2019 - М: Техносфера, 2019. С. 450-454.

[2] Автоматное управление асинхронными процессами в ЭВМ и дискретных системах (под ред. В.И.Варшавского) – М.: НАУКА, 1986. – 308 с.

[3] Л. П. Плеханов. Основы самосинхронных электронных схем – М.: БИНОМ. Лаборатория знаний, 2013. — 208 с.

[4] И.А. Соколов, Ю.А. Степченков, С.Г. Бобков, В.Н. Захаров, Ю.Г. Дьяченко, Ю.В. Рождественский, А.В. Сурков, Базис реализации супер-ЭВМ эксафлопсного класса // Информатика и ее применения. 8(1), 2014. С. 45-70.

[5] Yosys Open SYnthesis Suite. URL:http://www.clifford.at/yosys/download.html (дата последнего обращения 09.08.2021).

[6] Ю.А. Степченков, А.Н. Денисов, Ю.Г. Дьяченко, Ф.И. Гринфельд, О.П. Филимоненко, Н.В. Морозов, Д.Ю. Степченков, Л.П. Плеханов. Библиотека функциональных ячеек для проектирования самосинхронных полузаказных БМК микросхем серий 5503/5507. М.: Техносфера. 2017. 367 с. — ISBN 978-5-94836-332-5. URL: http://www.technosphera.ru/lib/ book/497 (дата последнего обращения 09.08.2021).

[7] Степченков Ю.А., Дьяченко Ю.Г., Петрухин В.С. Опыт разработки самосинхронного ядра микроконтроллера на базовом матричном кристалле // Нано- и микросистемная техника, №5, 2006., с.29-36.

[8] Fant K.M., Brandt S.A. NULL convention logic: a complete and consistent logic for asynchronous digital circuit synthesis // Proceedings of the International Conference on Application Specific Systems, Architectures, and Processors, 1996. P. 261–273.